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CLAIMS 

— — 3> 1. A method for splicing data streams of MPEG-compressed programs, the 

program data being carried in MPEG transport streams of data packets having 
5 program clock references referring to an MPEG encoder system clock, the / data 

packets carrying application data, such as video and audio data, and a header provided 
with control data, the method including the steps of: 

-receiving a first input transport stream of first data packets (/(); 
-receiving a second input transport stream (1) of second cjata packets to replace 
10 selected first data packets in said first stream; 
11 -extracting for each data packet a time reference and / data packet status 

l\ information mdicating the syntactic function of the daja packet; 

^ characterised in the steps of: 

j| -establishing for each data packet a controL^ata object storing said time 

15 reference and said data packet status irifonnati^;-establishing for ordered sets of said 
first data packets corresponding ordered sets of control data objects; 

-estabUshing for said ordered sets oft control data objects other control data 
II objects storing information pertaimng/to different logical structures such as frames, 

l[ sequences of frames and packetized'elernentary stream packets ;-queueing the control 

20 data objects in different queues dependent on the data packet status or on the status of 
a group of data packets-selecting from the queues control data objects associated to 
data packets to be output ii/an output stream of data packets-assembling selected 
control data objects to a/program of associated data packets of different kinds of data;- 
assembling data packets associated to said selected and assembled control data objects 
25 to an output $treany(3) of data packets; 

-outputtine'said assembled stream (3) of data packets. 

2. The method for splicing programs as recited in claim 1, wherein the step of 
assembling data packets to an output stream comprises the further step of generating 
3 0 and inserting padding packets to fill out unutilised space in terms of free bandwidth of 
the output transport stream. 
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3. The method fox splicing programs as recited in claim 1, wherein the control 
objects are used to generate control information for operating on associated data 
packets, 

4. The method for splicing programs as recited in claim 1, wherein data 
packets axe marked as available or non-available for replacement/and non-available 
data packets being left intact and reassembled into the output stream of data packets. 

5. The method for splicing programs as recited in clajm^l, wherein said 
operations are carried out on different layers of the transport streams generating 
different layers of abstraction of control data objects. 

6. The method for splicing programs as recital in claim 1, further comprising 
the steps of: 

-genlocking to an encoder clock of a received fj/st input transport stream (1) wherein 
some packets include a program clock reference; 

-determining according to said clock an arrival time in the shape of a local clock 
reference of every transport stream packet in the incoming transport stream (1) ; the 
local clock references carrying information about which positions within a transport 
stream at winch all its transport strea^h. packets arrived. 

7. The method for splicing programs as recited in claim 1 7 further comprising 
the steps of: 

-genlocking to an encoder clo/k of a received second input transport stream (2) 
wherein some packets include a program clock reference; 

-detemiining according tc/said clock an arrival time in the shape of a local clock 
reference of every transport stream packet in the incoming master transport stream, 
the local clock references carrying information about which positions within a 
transport stream at Which all its transport stream packets arrived. 



8. Them* 
the step of: / 



nd for splicing programs as recited in claim 1, further comprising 
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-translating the time base of said second input transport stream to the time base of 
said first input transport stream. 



lim 1, wherein video 



^roups-of-pictures such 
is not depend on any 
ed group -of-pictures; 



9. The method for splicing programs as recited in c 
pictures comprised in the transport streams are arranged in 
that each I-picture belongs to a group-of-pictuxes which do 

previous pictures as reference for its decoding, called a clo, 
further comprising the step of: / 

-generating, for an intra-coded I-picture a closed group -of-pictures property by- 
eliminating the unwanted B -pictures that have an earlier presentation time than, said I-- 
picture. 



10. The method for splicing programs as recited in claim 1, further comprising 

/ 

the steps of: 

-selecting one of two candidate I-pictures at which the first input transport stream is 
re-entered dependent on a current program delay and the time distance from a desired 
switch tim e to a presentation time stamp of each candidate I-picture. 



1 1. The method for splicing programs as Recited in claim 1, further comprising 
the step of controlling buffer violations in the decoder by using free bandwidth in the 



form of empty packets in said first program's ' 
packets in said transport stream thereby disalk 
decoders buffers. 



Dort stream to re-schedule transport 
lg overflow or underflow in said 



12. An apparatus for splicing data streams in MPEG-compressed programs, the 
program data being carried in MPEG transport streams of data packets having 
program clock references referring to an MPEG encoder system clock, the data 
packets carrying application data, such ai video and audio data, and a header provided 
with control data, the apparatus having means for: 

-means (4) for receiving a first input transport stream (1) of first data packets; 

-means (5) for receiving a secona input transport stream (2) of second data 
packets to replace selected first data packets in said first stream (1); 
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of the data packet; 
racket a control data object storing 



-means for extracting for each data packet a faie reference and data packet 
status information indicating the syntactic function 
characterised in 

-means (6,7,8) for establishing for each data 
said time reference and said data packet status information; -means (6,7,8) for 
establishing for ordered sets of said first data packets corresponding ordered sets of 
control data objects; 

-means (6,7,8) for establishing for said ordered sets of control data objects other 
control data objects storing information pertaining to different logical structures of 
higher level than the data packets such as frames, sequences of frames and pacLcetized 
elementary stream paclcets;-nieans (11,12) for queueing the control data objects in 
different queues dependent on the data packet statrus or on the status of a group of data 
packets;-means (13,15) for selecting from the queues control objects associated, to 
data packets to be output in an output stream of ^ata packets; -means (17) for 
assembling selected control objects to a program of associated data packets of 
different kinds of data; -means (25) for assembling data packets associated to said 
selected and assembled control data objects to an output stream (3) of data packets; 

-means (20) for ontputtirig said assembled stream (3) of data packets. 



20 13. The apparatus for splicing pro grams as recited in claim 12, wherein the 

means for assembling (25) data packets to an output stream is devised to generate 
padding packets to fill out unutilized spacp in terms of free bandwidth of the output 
transport stream. 

25 14. The apparatus for splicing pto grams as recited in claim 12, comprising 

means for using the control objects ttjf generate control information for operating on 
associated data packets. 



15. The apparatus for splicing programs as recited in claim 12, comprising 
30 means for marking data packets as available or non-available for replacement, and 
means for leaving non-available £ata packets intact and reassembled into the output 
stream of data packets. 
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16. The apparatus for splicing programs as recited in claim 12, comprising 
means for carrying out operations on different layers oflthe transport streams 
generating different levels of abstraction of control data objects. 



17. The apparatus for splicing programs as recited in claim 12, further 
comprising: j 

-means for genlo eking to an encoder clock of a received first input transport stream 
wherein some packets include a program clock reference; 
10 -means for determining according to said clock an arrival time in the shape of a local 
clock reference of every transport stream packet in. the incoming first input transport 
stream , the local clock references carrying information about which positions within a 
transport stream at which all its transport stream/packets arrived. 

15 IS. The apparatus for splicing programs ks recited in claim 12 5 further 

comprising: 

-means for genlocking to an encoder clock of a received second input transport stream 
wherein some packets include a program clock reference; 

-means for determining according to said cflock an arrival time in the shape of a local 
20 clock reference of every transport strearry packet in the incoming first input transport 
stream, the local clock references carrying information about which positions within a 
transport stream at which all its transpo/tt stream packets arrived. 

19. The apparatus for splicing programs as recited in claim 12, further 
25 comprising: 

-means for translating the time bas/e of said second input transport stream to the time 
base of said first input transport steam. 



20. The apparatus for splicing programs as recited in claim 12, wherein video 
30 pictures comprised in the transport streams are arranged in group s-of-pictures such 
that each I-picture belongs to a group-of-pictures which does not depend on any 
previous pictures as reference/for its decoding, called a closed group-of-pictures; 
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further comprising: 

-means for generating, for an Lntra-coded I-picture 
property by eliminating the unwanted B -pictures 
than said I-picture. 



a closed group-of-pictures 
it have an earlier presentation time 
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21 . The apparatus for splicing programs as recited in claim 12, further 
comprising: 

-means for selecting one of two candidate I -pictures at which the fust input transport 
stream is re-entered dependent on a current prdgrani delay and the time distance from 
a desired switch time to a presentation time stlmp of each candidate I-picture. 
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22. The apparatus for splicing programs as recited in claim 12, further 
comprising means for controlling buffer violations in the decoder by using free 
bandwidth in empty packets in said first irA>ut transport stream to re-schedule 
transport packets in said transport stream/thereby disallowing overflow or underflow 
in said decoders buffers. 
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23. A computer program prodtict for splicing data streams in MPEG- 
compressed programs, the program dlta being carried in MPEG transport streams of 
data packets having program clock references referring to an MPEG encoder system 
clock, the data packets carrying application data, such as video and audio data, and a 
header provided with control dataVthe computer program product comprising a 
recording medium and being characterised in means, recorded on the recording 
medium, to direct a computer tr| perform the steps and the functions as recited in any 
of the claim ^ \^±. 



